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This invention relates to computers, and particularly to a method 
5 for allowing a partial instruction to be executed in a fixed 
point unit pipeline during the instruction dispatch cycle. 



Trademarks: S/390 and IBM are registered trademarks of 
International Business Machines Corporation, Armonk, New York, 
U.S.A.. Other names may be registered trademarks or product names 
10 of International Business Machines Corporation or other 
companies . 



Background: 

The invention relates to computers and representative of the 
computers which can implement the invention has been the IBM 

15 S/390 system, but it could be another system. Such a system would 
have a Fixed Point Unit for the computer, or FXU, which acts as 
the integer execution unit of the Central Processor (CP) unit of 
the computer system, be it an IBM S/390 system, or that of other 
systems. The Fixed Point Unit (FXU) contains an Arithmetic and 

20 Logical Unit (ALU) which is capable of performing arithmetic 
functions such as binary addition, subtraction, as well as 
logical operations such as logical and, logical or, and logical 
exclusive or. These logical operations are bit maskable which 
means that a mask is used to select which bits of the operands 
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participate in the logical operation. The unselected bits of the 
result are left unchanged. This mask is either explicitly 
specified in the instruction text as the location of the 
beginning and ending bit positions of a contiguous mask or the 
5 instruction may implicitly require a mask. The mask is also used 
for a variety of other instructions including shift operations 
and stores. The execution of the logical operation is serially 
gated by the construction of the mask. We found that it was not 
possible to reduce the processor cycle time without increasing 
10 the number of cycles required to perform the bit maskable 
operations until we discovered our improved method described 
below. 

Summary of the Invention: 

In accordance with our invention, a method for allowing a 

15 partial instruction to be executed in a fixed point unit pipeline 
during the instruction dispatch cycle creates a mask used to 
select which bits of the operands participate in a future logical 
operation of the fixed point unit back a cycle to the instruction 
dispatch stage of the fixed point unit. In such a case, for an 

20 S/390 System improvement, the mask is determined and created two 
cycles ahead of execution, or two cycles before the mask is 
actually used. Also, in the method used for moving the mask 
generation back by one cycle, mask generation overlaps the 
dispatch stage in the I-unit, and we define thus a new handshake 

25 between the I-unit and E-unit of the fixed point unit of the 
central processor unit of the computer system. 
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These and other improvements are set forth in the following 
detailed description. For a better understanding of the invention 
with advantages and features, refer to the description and to the 
drawings . 

5 Description of the Drawings: 

FIGURE 1 illustrates the Fixed Point Unit data flow and timing 
unit flow for the mask generator. 

FIGURE 2 illustrates the control setting selection process that 
occurs in the e-1 (eml) stage for the mask generation and the 
10 register file read address. 

Our detailed description explains the preferred embodiments 
of our invention, together with advantages and features, by way 
of example with reference to the drawings. 

Detailed Description of the Invention: 

15 It will be seen from Figure 1 which illustrates our preferred 
embodiment the integer execution unit of the central processor 
unit (here the Fixed Point Unit -FXU which we provide in our 
preferred embodiment) has a control and data pipeline. The 
control pipeline is divided into four stages for instruction 

20 execution. These four stages shown in Figure 1 are an e-1 (eml) 
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stage and eO stage, and el stage and a putaway (pa) stage. The 
dataflow comprises a register array 30, an input register 40, the 
arithmetic logic unit (ALU) 20, input register multiplexers 60 
for muxing the different values of the operands into the working 
5 registers, mask generation logic 70 for generating the operand 
masks, and the write register 50. These stages are connected in 
an ordered manner such that the processing of instructions occurs 
in the dataflow pipeline which receives the data and control 
input and performs integer instruction execution. 

i 

10 During the eml stage an instruction is presented to the control 
j stack of the integer execution unit fixed point unit FXU. This 

instruction is not validated during this stage. At this stage is 

i 

not determined if the instruction is an instruction whose 
execution should complete. During the eO stage, the register file 
15 is accessed to acquire the operands required for computation. 

During the eO state the fixed point unit FXU is informed that the 
instruction that was presented to the eml stage was indeed valid 
and requires computation. During the el stage the ALU 20 is used 
to perform the required computation. The ALU is capable of 
| 20 performing arithmetic functions such as binary addition, 

subtraction, as well as logical operations such as Logical AND, 
Logical OR and Logical exclusive or (XOR) . These logical 
operations are bit maskable. A mask is used to select which bits 
of the operands participate in the logical operation in a bit 
25 maskable logical operation. The unselected bits of the result are 
left unchanged in this operation. This mask is either explicitly 
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specified in the instruction text as the location of the 
beginning and ending bits positions of a contiguous mask of the 
instruction may implicitly require a mask. The resultant data is 
outputted from the pipeline along with controls on the put away 
5 (pa) cycle through the write register 50. The control and data 
output is used to update architectural information. 

It will be noted that in our operations, the control pipeline for 
FXU instructions is divided up into three pipeline stages, the 
E0, the El, and the PA stages. The E0 is the stage when the 

10 instruction is being decoded to determine what instruction it is 
in order to setup the controls to the ALU . During this cycle the 
operands are read and loaded into the FXU input registers. The El 
stage is the first cycle of execution where the input operands 
feed the ALU and the result is put into the result register. The 

15 final stage is the PA cycle where the contents of the result 
register are sent to the architected General Purpose Register 
file, GPR. These three pipeline stages can work independently so 
that they can contain three different instructions in various 
states of execution. 

20 In addition to the three pipeline stages we provide what we call 
an e-1 (eml) "stage" which overlaps with the I-unit dispatch 
stage and this e-1 stage sets the controls for the mask 
generation and for the general purpose registers (gprs) read 
addresses. ■ In the handshaking, this arrangement allows the 

25 commencement of execution even though it has not been finally 
determined that the instruction is one whose execution should 
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complete. It might be kept, thrown away or otherwise handled at 
this "stage". During eO stage we receive confirmation that what 
was sent in the previous cycle contains valid information for an 
instruction whose execution should completed. 

5 Thus, in order to allow the processor cycle time to be 

reduced, the mask generation process was divided into two 
processes and partitioned among two pipeline stages. A new FXU 
pipeline stage was created to accommodate the first part of the 
mask generate process. This stage is called the E-l stage and it 

10 is inserted before the EO stage. The addition of this pipeline 
stage did not increase the depth of the FXU pipeline. This E-l 
stage overlaps with the last stage or dispatch stage of the 
Instruction Decode and Dispatch Unit, I-Unit. During the E-l 
stage this instruction is physically in transit from the I-Unit 

15 to the FXU. The instruction text is then examined by the first 
mask generation process to see if the mask starting and ending 
bit position are explicitly defined in the instruction text. If 
not, the instruction is decoded to calculate the implied mask 
starting and ending bit position. This mask information is 

20 latched into registers at the end of the E-l stage. It will then 
be used by the following EO stage on the next cycle. In the EO 
stage, the entire 64 bit mask is created using the mask start and 
end bit positions. This 64 bit mask is latched in a register at 
the end of the EO stage. It will then be used by the ALU in the 

25 El stage. 
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As Figure 1 . shows a timing flow of the mask gen 
(generating) logic, while Figure 2 shows a more detailed 
description of the mask generator logic, these Figures show how 
during the E-l stage ( eml stage), the mask will be defined by 
5 setting the mask_start, mask_end, comp__mask and spec_mask 
signals. 

In order to minimize the processor cycle time all of the dataflow 
controls (100) originate at the beginning of a cycle, at the e) 
cycle, as from latches. To accomplish this control signals are 

10 formed in the cycle before they are required (e.g. during eml) to 
be sent to the dataflow. In the case of the Register Array read 
address the control inputs to the mask generation process, this 
new virtual eml stage incorporates the register read address 
selection 80 and the mask selection 90 processes which are a 

15 function of the instruction text of a potential incoming 
instruction. 

Since there is not signal to confirm that the eml stage contains 
a valid instruction, control speculation is used. At any instance 
in time the control signals feeding the dataflow (control for the 
20 mask and array read addresses in this case) are selected from 
among : 

eml controls (200) which are set during the eml stage; 
the eO stage controls (210); 

execution control (220) for the el cycle until the cycle 
25 before endop (end of operation); and 
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the hold control (230) where control lines are kept the same. 
The e-1 (eml) control 2 00 is selected when no other control 
stages are selected. The speculative control selection for eml 
control complicates the control equations for other control 
5 signals since there can be no other "don't care" possibilities 
left available for logic reduction. As a result meeting the 
timing or frequency requirements for the eml control is complex 
because it depends on the output of other units, but it is 
achievable. 

1 0 Simplified equations that handles the speculative handshaking between I-Unit and FXU are: 



Equations for the first level of muxing that handles part of the I-unit to E-unit handshaking of 
instructions. 

nexti_sel <= 

( (valid_eO_setl or valid_e0_set2) and (not iu_eu_data_blocked) and (not iu_eu__excpt_4)end)) or 
1 5 (not iu_eu_nexti_ready); 

nextijild <= (not nexti_sel) 



where 

valid_e0_setl : fau_rdy__4_any and fpu_rdy_4_any. 

valid_e0_set2 : fxu_rdy_4_any and ovrlp_ex_set and fpu_rdy_4_ovlp. 

20 fxu_rdy_4_any : FXU is ready to accept new instruction into E0 stage from the I-unit. 
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fpu_rdy_4_any : FPU (Floating Point Unit) is ready to accept new instruction into EO stage 
from the I-unit. 

ovrlp_ex_set: An I-Unit input indicating that I-unit is issuing an FPU instruction that can 

be overlapped with other FPU instructions already in FPY pipe. 
5 fpu_rdy_4_ovIp : FPU is busy but can accept a new instruction that can be overlapped with 

the current executing FPU instrcuctions. 
iu_eu_dataJblocked: Data requested from cache is not ready yet. This signal is active in the 

El -cycle of an instruction and caused a freeze of the FXU/FPU pipes. 
iu_eu_excpt_pend: There is a possible exception associated with an instruction. This signal is 
10 active in the El -cycle of an instruction and caused a freeze of the 

FXU/FPU pipes. 

The confirmation for an E-l instruction occurs a cycle later in EO stage when signal nextLsel is 
set. As long as there is no confirmation of a valid E-l instruction, the EU keeps ingating a new 
instruction from the I-unit. As mentioned earlier, the mask generation and GPR read addresses 
15 for FXU instructions are selected from among eml controls (200), eO controls (210), execution 
controls (220) and hold controls (230). Therefore, there exist another level of muxing (other than 
nextLsel, nexti_hld) that sets the mask and GPR read addresses. 

The controls of 2nd level of muxing is less timing critical than the first level since most of the 
signals involved are instruction and FXU dependent. To make cycle time, the two muxes are 
20 combined together, but the eml controls (200) is divided as follows: 
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reg_sel_eml _part and nexti_sel 
reg_sel_eml _part and nextijild 

Where reg_sel_eml _part is the default selection for when eO controls, execution controls and 
hold controls are all clear. All control lines are verified to be orthogonal at any time. The final 
5 equation can be set as: 



sel_eml_next : 
sel_eml_hold : 



new_mask_value <= 

(eO_mask_value when eO control are set )or (210) 

(ex_mask_value when execution controls are set ) or (220) 

(old_mask_value when hold signals are are set ) or (230) 

10 (new__eml_mask when sel_eml_next is set )or (200, new value) 

(eml_mask_hld when sel_eml_hld is set ); (200, held value) 



The creation of the E-l pipeline stage also provides cycle 
time relief of the E0 stage by allowing an extra cycle to decode 
15 the instruction and form the GPR read addresses which need to be 
launched directly from latches at the beginning of the E0 cycle. 

The E-l stage of the mask generator logic overlaps with the 
I-unit instruction unit as well as with the execution cycles of 
older (earlier in the pipeline) instructions. It will be noted 
20 that the E-l pipeline stage is implemented as a speculated 
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pipeline stage. The validity of the E-l stage is not known until 
the stage following, the EO stage. This minimizes the impact to 
the I-Unit. If an EO stage first becomes valid, it is implied 
that the E-l stage was valid on the cycle before. This 
5 speculative handshaking allows the E-l stage to be created with 
no impact to the last stage of the I-Unit, i.e. no additional 
logic is needed and cycle time is not jeopardized. Also, the E-l 
stage of an instruction overlaps with the execution stages of 
previous instructions . 

10 With this process, we can now implement in a computer system 

having an integer execution unit of the Central Processor (CP) 
which contains an Arithmetic and Logical Unit (ALU) which is 
capable of performing arithmetic functions including binary 
addition, subtraction, and logical operations such as logical 

15 and, logical or, and logical exclusive or. The logical operations 
are bit maskable to select which bits of the operands participate 
in the logical operation. With this system we proceed with the 
method for allowing a partial instruction to be executing during 
the instruction dispatch cycle of the computer system. This 

20 method makes use of the FXU pipeline stage created to accommodate 
the first part of the mask generate process. This E-l stage is 
inserted before the EO stage. The addition of this pipeline stage 
did not increase the depth of the FXU pipeline. This E-l stage 
overlaps with the last stage or dispatch stage of the Instruction 

25 Decode and Dispatch Unit, I-Unit. 
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The method proceeds by dividing a timing critical function 
(e.g. a mask generation process or read addresses for the GPRs) 
used for execution of an instruction into first and second 
partitioned processes partitioned among a first and a second 
5 pipeline stage of a single pipeline. 

The first partitioned process has a predetermination cycle 
(eml) which initiates two cycles before a first cycle of 
execution of said instruction when the input operands feed the 
ALU and the result is put into a result register and which 

10 initiates the timing critical function for execution of an 
instruction to be executed. 

The second partitioned process has a first cycle (eO) and a 
second cycle (el) and a third cycle (PA) and the first cycle (eO) 
is initiated when an instruction is being decoded to determine 

15 what instruction it is in order to setup the controls to the 
computer system ALU and the second partitioned process is used 
for reading and loading operands into the computer system's FXU 
input registers which cycle determines whether the timing 
critical function of said predetermined cycle is valid for an 

20 instruction to be executed, and the second cycle (el) performs 
the first cycle of execution of said instruction where the input 
operands feed the ALU and the result is put into a result 
register, and during the third cycle (PA) the contents of the 
result register are sent to the architected General Purpose 

25 Register file (GPR) . 

In the process allowing a partial instruction to be executing 
during the instruction dispatch cycle of the computer system, the 
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three pipeline cycles of the second partitioned process said 
pipeline stages work independently so that they contain three 
different instructions in various states of execution. The first 
partitioned process overlaps with the I-unit instruction pipeline 
5 as well as with the execution cycles of earlier in the pipeline 
instructions . 

While the preferred embodiment to the invention has been 
described, it will be understood that those skilled in the art, 
both now and in the future, may make various improvements and 
10 enhancements which fall within the scope of the claims which 
follow. These claims should be construed to maintain the proper 
protection for the invention first described. 
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